| ФИО             | Завьялов Никита Аркадьевич |
|-----------------|----------------------------|
| Номер группы    | M3138                      |
| Название работы | Построение логических схем |

- 2. Ссылка на репозиторий: https://github.com/NEKAfk/comp-ach
- 3. Инструментарий: Logisim Evolution v. 3.8.0, Icarus Verilog v. 11.0(stable)
- 4. Сборка схем в Logisim Evolution

Four\_bit\_cell — ячейка памяти на 4 бита, состоящая из четырёх D триггеров. Значение обновляется если во время CLK = 1 и нам пришла команда записи $(W_R = 1)$ 



half\_sub – модуль, позволяющий находить разность битов и занимаемый бит



full\_sub – модуль, позволяющий находить разность битов и занимаемый бит, учитывая занятый бит с предыдущего разряда



get\_val — модуль возвращающий индекс элемента в массиве, принимая индекс элемента в стеке Так как  $0 \le 1$  Index  $0 \le 1$  Head  $0 \le 1$  Head  $0 \le 1$  Head  $0 \le 1$  Писков индекс элемента в стеке следующий push, то реализовав (Head  $0 \le 1$  Index  $0 \le 1$  Писков индекс в массиве.



| Head/Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
|------------|---|---|---|---|---|---|---|---|
| 0          | 4 | 3 | 2 | 1 | 0 | 4 | 3 | 2 |
| 1          | 0 | 4 | 3 | 2 | 1 | 0 | 4 | 3 |
| 2          | 1 | 0 | 4 | 3 | 2 | 1 | 0 | 4 |
| 3          | 2 | 1 | 0 | 4 | 3 | 2 | 1 | 0 |
| 4          | 3 | 2 | 1 | 0 | 4 | 3 | 2 | 1 |

Head – модуль, хранящий указатель на элемент массива, в который добавится элемент при выполнении команды push. up\_down отвечает за инкрементирование/декрементирование счетчика, при переполнении счетчик сбрасывается до нуля или четырёх.



Inout – сделан за счет двух транзисторов (cmos в Veriog). Блок gate отвечает за открытие затвора, затвор открывается, если clk = 1 и команда – pop или push.



## 5. Сборка схемы на Verilog

В структурном уровне все модули аналогичные

В поведенческом уровне стек устроен как двумерный массив  $5\times4$ , имеется два блока always, которые вызываются при posedge RESET и posedge CLK соответственно. Когда срабатывает сброс все значения обнуляются при помощи блока for. Inout IO\_DATA подсоединен при помощи assign IO\_DATA = (CLK && (COMMAND ==  $2 \mid \mid$  COMMAND == 3)) ? O\_DATA\_reg : 4'bz; То есть если нам надо выводить, мы выводим значение O\_DATA\_reg, которое присваивается внутри блока always, иначе подается высокоимпедансное состояние, которое вместе с I\_DATA даст I\_DATA.